## WE CLAIM:

An error correction system, comprising:
an input buffer, connected to a first port;
a latch, connected to the input buffer, for latching data;
an edit buffer having an error portion for storing an error correction word
and a data portion for storing a data word:

an error word generator having an input and an output, the input connected to the latch and the output connected to the edit buffer, for generating an error word based on data in the latch;

a compare circuit, connected to the error word generator and the edit portion of the edit buffer, for generating an error signal based on the error word and the error correction word in the error portion of the edit buffer;

a first data bus, connecting the input of the error word generator to the data portion of the edit buffer; and

a second data bus, connecting the data portion of the edit buffer to an output latch and connecting the output latch to the first port; wherein the edit buffer has an error word port for the error portion and a data word port for the data portion.

- The error correction system of claim 1, wherein the data portion of the
  edit buffer comprises a header portion and a raw data portion and wherein the
  data word port has a header word port for the header portion and a raw word port
  for the raw word portion.
- 3. The error correction system of claim 1, wherein the data portion of the edit buffer comprises a header portion and a prepend data and postpend data portion and wherein the data word port has a header word port for the header portion and a prepend and postpend data port for the prepend data and postpend data

The error correction system of claim 1, wherein the error word generator is a cyclical redundancy check generator.

- 5. The error correction system of claim 2, wherein the error word generator is a cyclical redundancy check generator.
- 6. The error correction system of claim 3, wherein the error word generator is a cyclical redundancy check generator.
- 7. A method for error detection and correction of a data word having a data portion, a header-portion, and an error correction portion, comprising the steps of:

simultaneously transmitting the data portion to a latch and the header portion to an error signal generator;

generating an error signal from the error signal generator based on the header portion and the error correction portion;

if the error signal is negative, then enabling the latch to transmit the data word; and

if the error signal is positive, then disabling the latch to inhibit transmission of the data word.

A method for cyclical redundancy check error generation in a system having a cyclical redundancy check generator, a data latch, and a data buffer connected by a plurality of data bus lines, the data latch having a precharge circuit and the data buffer having data buffer outputs, the method comprising the steps of:

inhibiting the cyclical redundancy check generator and the data buffer outputs;

precharging the plurality of data bus lines to a first logic level until a cyclical redundancy check strobe is detected;

turning off the precharge circuit;

activating the data buffer outputs to modulate charge on the plurality of data bus lines:

waiting for a sufficient-time for the plurality of data bus lines to develop a charge differential;

latching the plurality of data bus lines on the data latch; and performing a cyclical redundancy check on data latched by the data latch.

A method for performing multiple operations in a single cycle in a cyclical redundancy check system, the system having a port, an input buffer, an input latch, a first data bus, a register, an output latch, and a second data bus, the method comprising the steps of:

activating the input buffer to receive data from the port;
latching data from the input buffer into the input latch;
disabling the input buffer;
transmitting data on the input latch to the first data bus; and
activating the output latch to transfer the contents of the second data bus
to the port.

 The method of claim 9, further comprising the steps of: storing data on the kirst data bus in the register, and processing data stored in the register.

Adal